# Copyright 2019 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

# NOTE: This file is auto generated by the elixir code generator program.
# Do not edit this file manually.

defmodule GoogleApi.IAM.V1.Model.ServiceAccount do
  @moduledoc """
  An IAM service account. A service account is an account for an application or a virtual machine (VM) instance, not a person. You can use a service account to call Google APIs. To learn more, read the [overview of service accounts](https://cloud.google.com/iam/help/service-accounts/overview). When you create a service account, you specify the project ID that owns the service account, as well as a name that must be unique within the project. IAM uses these values to create an email address that identifies the service account. //

  ## Attributes

  *   `description` (*type:* `String.t`, *default:* `nil`) - Optional. A user-specified, human-readable description of the service account. The maximum length is 256 UTF-8 bytes.
  *   `disabled` (*type:* `boolean()`, *default:* `nil`) - Output only. Whether the service account is disabled.
  *   `displayName` (*type:* `String.t`, *default:* `nil`) - Optional. A user-specified, human-readable name for the service account. The maximum length is 100 UTF-8 bytes.
  *   `email` (*type:* `String.t`, *default:* `nil`) - Output only. The email address of the service account.
  *   `etag` (*type:* `String.t`, *default:* `nil`) - Deprecated. Do not use.
  *   `name` (*type:* `String.t`, *default:* `nil`) - The resource name of the service account. Use one of the following formats: * `projects/{PROJECT_ID}/serviceAccounts/{EMAIL_ADDRESS}` * `projects/{PROJECT_ID}/serviceAccounts/{UNIQUE_ID}` As an alternative, you can use the `-` wildcard character instead of the project ID: * `projects/-/serviceAccounts/{EMAIL_ADDRESS}` * `projects/-/serviceAccounts/{UNIQUE_ID}` When possible, avoid using the `-` wildcard character, because it can cause response messages to contain misleading error codes. For example, if you try to access the service account `projects/-/serviceAccounts/fake@example.com`, which does not exist, the response contains an HTTP `403 Forbidden` error instead of a `404 Not Found` error.
  *   `oauth2ClientId` (*type:* `String.t`, *default:* `nil`) - Output only. The OAuth 2.0 client ID for the service account.
  *   `projectId` (*type:* `String.t`, *default:* `nil`) - Output only. The ID of the project that owns the service account.
  *   `uniqueId` (*type:* `String.t`, *default:* `nil`) - Output only. The unique, stable numeric ID for the service account. Each service account retains its unique ID even if you delete the service account. For example, if you delete a service account, then create a new service account with the same name, the new service account has a different unique ID than the deleted service account.
  """

  use GoogleApi.Gax.ModelBase

  @type t :: %__MODULE__{
          :description => String.t() | nil,
          :disabled => boolean() | nil,
          :displayName => String.t() | nil,
          :email => String.t() | nil,
          :etag => String.t() | nil,
          :name => String.t() | nil,
          :oauth2ClientId => String.t() | nil,
          :projectId => String.t() | nil,
          :uniqueId => String.t() | nil
        }

  field(:description)
  field(:disabled)
  field(:displayName)
  field(:email)
  field(:etag)
  field(:name)
  field(:oauth2ClientId)
  field(:projectId)
  field(:uniqueId)
end

defimpl Poison.Decoder, for: GoogleApi.IAM.V1.Model.ServiceAccount do
  def decode(value, options) do
    GoogleApi.IAM.V1.Model.ServiceAccount.decode(value, options)
  end
end

defimpl Poison.Encoder, for: GoogleApi.IAM.V1.Model.ServiceAccount do
  def encode(value, options) do
    GoogleApi.Gax.ModelBase.encode(value, options)
  end
end
